package com.example.mapper;

import com.example.entity.UserNoticeRead;
import org.apache.ibatis.annotations.Mapper;
import org.apache.ibatis.annotations.Param;

import java.util.List;

@Mapper
public interface UserNoticeReadMapper {
    
    /**
     * 插入阅读记录
     */
    int insert(UserNoticeRead userNoticeRead);
    
    /**
     * 根据用户ID和通知ID查询阅读记录
     */
    UserNoticeRead selectByUserIdAndNoticeId(@Param("userId") Long userId, @Param("noticeId") Long noticeId);
    
    /**
     * 根据用户ID查询已读的通知ID列表
     */
    List<Long> selectReadNoticeIdsByUserId(@Param("userId") Long userId);
    
    /**
     * 获取用户未读通知数量
     */
    long selectUnreadCountByUserId(@Param("userId") Long userId);
    
    /**
     * 批量标记已读
     */
    int batchInsert(@Param("userId") Long userId, @Param("noticeIds") List<Long> noticeIds);
    
    /**
     * 删除用户的所有阅读记录
     */
    int deleteByUserId(@Param("userId") Long userId);
}
